<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xml:lang="en" xmlns="http://www.w3.org/1999/xhtml">

<head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <title>猜先生-憨憨</title>
  <link type="text/css" rel="stylesheet" href="./static/default.css">
  <script type="text/javascript" src="./static/jquery.min.js"></script>
  <script type="text/javascript" src="./static/jscex.min.js"></script>
  <script type="text/javascript" src="./static/jscex-parser.js"></script>
  <script type="text/javascript" src="./static/jscex-jit.js"></script>
  <script type="text/javascript" src="./static/jscex-builderbase.min.js"></script>
  <script type="text/javascript" src="./static/jscex-async.min.js"></script>
  <script type="text/javascript" src="./static/jscex-async-powerpack.min.js"></script>
  <script type="text/javascript" src="./static/functions.js" charset="utf-8"></script>
  <script type="text/javascript" src="./static/love.js" charset="utf-8"></script>
  <style type="text/css">
    .STYLE1 {
      color: #666666
    }

    body,
    html {
      height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
    }
  </style>
</head>

<body>
  <audio src="./love.mp3" id="audios" autoplay preload loop="loop"></audio>
  <div id="main">
    <div id="error">本页面采用HTML5编辑，目前您的浏览器无法显示，请换成谷歌(<a
        href="http://www.google.cn/chrome/intl/zh-CN/landing_chrome.html?hl=zh-CN&brand=CHMI">Chrome</a>)或者火狐(<a
        href="http://firefox.com.cn/download/">Firefox</a>)浏览器，或者其他游览器的最新版本。</div>
    <div id="wrap">
      <!-- <div id="text">
        <div id="code">
          <font color="#FF0000">
            <span class="say">用心爱你</span><br>
            <span class="say">才会胡思乱想，才会吃醋</span><br>
            <span class="say">不是对你不信任</span><br>
            <span class="say">而是爱你已爱到心不由己，能够影响我的情绪</span><br>
            <span class="say">瞬间又能平复我心情的只有你</span><br>
            <span class="say"> </span><br>
            <span class="say">我虽然不是第一个拥抱你的人</span><br>
            <span class="say">也不是第一个牵你手的人</span><br>
            <span class="say">也不是你第一个喜欢的人</span><br>
            <span class="say">但我真的很希望</span><br>
            <span class="say">我是能够陪你到老的人</span><br>
            <span class="say"> </span><br>
            <span class="say">想让你记住，</span><br>
            <span class="say">而不是仅仅知道，无论什么时候，</span><br>
            <span class="say">随时随地，为你效劳。</span><br>
            <span class="say"> </span><br>
            <span class="say"><span class="space"></span> -- 猜先生--</span>
          </font>
        </div>
      </div> -->
      <div id="clock-box">
        <span class="STYLE1"></span>
        <font color="#33CC00">憨憨，我们相识</font>
        <span class="STYLE1">已经是……</span>
        <div id="clock"></div>
      </div>
      <canvas id="canvas" width="1100" height="680"></canvas>
    </div>
  </div>
  <script>
    function audioAutoPlay(id) {
      var audio = document.getElementById(id),
        play = function () {
          audio.play();
          document.removeEventListener("touchstart", play, false);
        };
      audio.play();
      document.addEventListener("WeixinJSBridgeReady", function () {
        play();
      }, false);
      document.addEventListener('YixinJSBridgeReady', function () {
        play();
      }, false);
      document.addEventListener("touchstart", play, false);
    }

    (function () {
      var canvas = $('#canvas');
      if (!canvas[0].getContext) {
        $("#error").show();
        return false;
      }
      var width = canvas.width();
      var height = canvas.height();
      canvas.attr("width", width);
      canvas.attr("height", height);
      var opts = {
        seed: {
          x: width / 2 - 20,
          color: "rgb(190, 26, 37)",
          scale: 2
        },
        branch: [
          [535, 680, 570, 250, 500, 200, 30, 100, [
            [540, 500, 455, 417, 340, 400, 13, 100, [
              [450, 435, 434, 430, 394, 395, 2, 40]
            ]],
            [550, 445, 600, 356, 680, 345, 12, 100, [
              [578, 400, 648, 409, 661, 426, 3, 80]
            ]],
            [539, 281, 537, 248, 534, 217, 3, 40],
            [546, 397, 413, 247, 328, 244, 9, 80, [
              [427, 286, 383, 253, 371, 205, 2, 40],
              [498, 345, 435, 315, 395, 330, 4, 60]
            ]],
            [546, 357, 608, 252, 678, 221, 6, 100, [
              [590, 293, 646, 277, 648, 271, 2, 80]
            ]]
          ]]
        ],
        bloom: {
          num: 700,
          width: 1080,
          height: 650,
        },
        footer: {
          width: 1200,
          height: 5,
          speed: 10,
        }
      }
      var tree = new Tree(canvas[0], width, height, opts);
      var seed = tree.seed;
      var foot = tree.footer;
      var hold = 1;
      canvas.click(function (e) {
        audioAutoPlay('audios');
        var offset = canvas.offset(), x, y;
        x = e.pageX - offset.left;
        y = e.pageY - offset.top;
        if (seed.hover(x, y)) {
          hold = 0;
          canvas.unbind("click");
          canvas.unbind("mousemove");
          canvas.removeClass('hand');
        }
      }).mousemove(function (e) {
        var offset = canvas.offset(), x, y;
        x = e.pageX - offset.left;
        y = e.pageY - offset.top;
        canvas.toggleClass('hand', seed.hover(x, y));
      });
      var seedAnimate = eval(Jscex.compile("async", function () {
        seed.draw();
        while (hold) {
          $await(Jscex.Async.sleep(10));
        }
        while (seed.canScale()) {
          seed.scale(0.95);
          $await(Jscex.Async.sleep(10));
        }
        while (seed.canMove()) {
          seed.move(0, 2);
          foot.draw();
          $await(Jscex.Async.sleep(10));
        }
      }));

      var growAnimate = eval(Jscex.compile("async", function () {
        do {
          tree.grow();
          $await(Jscex.Async.sleep(10));
        } while (tree.canGrow());
      }));
      var flowAnimate = eval(Jscex.compile("async", function () {
        do {
          tree.flower(2);
          $await(Jscex.Async.sleep(10));
        } while (tree.canFlower());
      }));

      var moveAnimate = eval(Jscex.compile("async", function () {
        tree.snapshot("p1", 240, 0, 610, 680);
        while (tree.move("p1", 500, 0)) {
          foot.draw();
          $await(Jscex.Async.sleep(10));
        }
        foot.draw();
        tree.snapshot("p2", 500, 0, 610, 680);

        // 会有闪烁不得意这样做, (＞﹏＜)
        canvas.parent().css("background", "url(" + tree.toDataURL('image/png') + ")");
        canvas.css("background", "#ffe");
        $await(Jscex.Async.sleep(300));
        canvas.css("background", "none");
      }));
      var jumpAnimate = eval(Jscex.compile("async", function () {
        var ctx = tree.ctx;
        while (true) {
          tree.ctx.clearRect(0, 0, width, height);
          tree.jump();
          foot.draw();
          $await(Jscex.Async.sleep(25));
        }
      }));
      var textAnimate = eval(Jscex.compile("async", function () {
        var together = new Date();
        together.setFullYear(2022, 12, 30); //时间年月日
        together.setHours(16); //小时	
        together.setMinutes(53); //分钟
        together.setSeconds(0); //秒前一位
        together.setMilliseconds(0); //秒第二位
        $("#code").show().typewriter();
        $("#clock-box").fadeIn(500);
        while (true) {
          timeElapse(together);
          $await(Jscex.Async.sleep(1000));
        }
      }));

      var runAsync = eval(Jscex.compile("async", function () {
        $await(seedAnimate());
        $await(growAnimate());
        $await(flowAnimate());
        $await(moveAnimate());
        textAnimate().start();
        $await(jumpAnimate());
      }));
      runAsync().start();

    })();
  </script>

</body>

</html>